package com.cc.gulimall.auth.controller;

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.TypeReference;
import com.cc.common.constant.AuthServerConstant;
import com.cc.common.utils.HttpUtils;
import com.cc.common.utils.R;
import com.cc.common.vo.MemberRsepVo;
import com.cc.gulimall.auth.feign.MemberFeignService;
import com.cc.gulimall.auth.vo.SocialUser;
import lombok.extern.slf4j.Slf4j;
import org.apache.http.HttpResponse;
import org.apache.http.util.EntityUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;

import javax.servlet.http.HttpSession;

import java.util.HashMap;
import java.util.Map;

/**
 * <p>Title: Oath2Controller</p>
 * Description：
 * date：2020/6/26 14:14
 */


@Slf4j
@Controller
@RequestMapping("/oauth2.0")
public class Oath2Controller {

    @Autowired
    private MemberFeignService memberFeignService;

    @GetMapping("/logout")
    public String login(HttpSession session) {
        if (session.getAttribute(AuthServerConstant.LOGIN_USER) != null) {
            log.info("\n[" + ((MemberRsepVo) session.getAttribute(AuthServerConstant.LOGIN_USER)).getUsername() + "] 已下线");
        }
        session.invalidate();
        return "redirect:http://auth.gulimall.com/login.html";
    }

    /**
     * 登录成功回调
     * {
     * "access_token": "2.00b5w4HGbwxc6B0e3d62c666DlN1DD",
     * "remind_in": "157679999",
     * "expires_in": 157679999,
     * "uid": "5605937365",
     * "isRealName": "true"
     * }
     * 汀西氟的我是你	---		2.00b5w4HGbwxc6B0e3d62c666DlN1DD
     */

    /*微博授权回调页*/
    @GetMapping("/weibo/success")
    public String weiBo(@RequestParam("code") String code, HttpSession session) throws Exception {

        // 根据code换取 Access Token
        Map<String, String> map = new HashMap<>();
        map.put("client_id", "3626829259");
        map.put("client_secret", "5b78e8464d04e1fcf8c95f25c4c85a33");
        map.put("grant_type", "authorization_code");
        map.put("redirect_uri", "http://auth.gulimall.com/oauth2.0/weibo/success");
        map.put("code", code);
        Map<String, String> headers = new HashMap<>();
//        在发请求，得到access token
        HttpResponse response = HttpUtils.doPost("https://api.weibo.com", "/oauth2/access_token", "post", headers, null, map);
        if (response.getStatusLine().getStatusCode() == 200) {
            // 获取到了 Access Token
            String json = EntityUtils.toString(response.getEntity());
            SocialUser socialUser = JSON.parseObject(json, SocialUser.class);

            // 相当于我们知道了当前是那个用户
            // 1.如果用户是第一次进来 自动注册进来(为当前社交用户生成一个会员信息 以后这个账户就会关联这个账号)
            R login = memberFeignService.login(socialUser);
            if (login.getCode() == 0) {
                /*MemberRsepVo要实现序列化接口，要存在session中*/
                MemberRsepVo rsepVo = login.getData("data", new TypeReference<MemberRsepVo>() {
                });

                log.info("\n欢迎 [" + rsepVo.getUsername() + "] 使用社交账号登录");
                // 第一次使用session 命令浏览器保存这个用户信息 JESSIONSEID 每次只要访问这个网站就会带上这个cookie
                // 在发卡的时候扩大session作用域 (指定域名为父域名)
                // TODO 1.默认发的当前域的session (需要解决子域session共享问题) ，已解决
                // TODO 2.使用JSON的方式序列化到redis,默认是JDK序列化，我们统一使用json序列化方式。两个问题均用GlMallSessionConfig配置文件解决，已解决
//				new Cookie("JSESSIONID","").setDomain("gulimall.com");
                session.setAttribute(AuthServerConstant.LOGIN_USER, rsepVo);
                // 登录成功 跳回首页
                return "redirect:http://gulimall.com";
            } else {
                return "redirect:http://auth.gulimall.com/login.html";
            }
        } else {
            return "redirect:http://auth.gulimall.com/login.html";
        }
    }
}
